# Basic logic gates











$$F = x$$
  
Driver

$$F = x y$$
AND

$$F = x +$$

$$= x + y$$

$$F = x \oplus y$$







$$= x \circ y \begin{vmatrix} 0 & 0 & 1 \\ 0 & 1 & 0 \\ 1 & 0 & 0 \\ 1 & 1 & 1 \end{vmatrix}$$

# Combinational logic design

#### A) Problem description

y is 1 if a is to 1, or b and c are 1. z is 1 if b or c is to 1, but not both, or if all are 1.

#### D) Minimized output equations





$$z = ab + b'c + bc'$$

#### B) Truth table

| I | nputs | Out | puts |   |
|---|-------|-----|------|---|
| a | b     | C   | У    | Z |
| 0 | 0     | 0   | 0    | 0 |
| 0 | 0     | 1   | 0    | 1 |
| 0 | 1     | 0   | 0    | 1 |
| 0 | 1     | 1   | 1    | 0 |
| 1 | 0     | 0   | 1    | 0 |
| 1 | 0     | 1   | 1    | 1 |
| 1 | 1     | 0   | 1    | 1 |
| 1 | 1     | 1   | 1    | 1 |

#### C) Output equations

$$y = a'bc + ab'c' + ab'c + abc' + abc'$$

$$z = a'b'c + a'bc' + ab'c + abc' + abc$$



#### Finite State Machines

- Finite State Machines (FSMs)
  - general models for representing sequential circuits
  - two principal types based on output behavior (Moore and Mealy)
- Basic sequential circuits revisited and cast as FSMs
  - shift registers
  - counters
- Design procedure for FSMs
  - state diagrams
  - state transition table
  - next state functions
  - potential optimizations
- Hardware description languages

Spring 2010

CSE370 - XIV - Finite State Machines I

#### Finite state machine

- A set of States the FSM is in one state at any time
- Inputs inputs used by the FSM
- Next state function Determines how the FSM moves from one state to another based on the state and the inputs
- Output function Compute the output based on current state (and possibly the inputs)
- The FSM transitions from one state to another as determined by the next state function function



Spring 2010

CSE370 - XIV - Finite State Machines I

#### Example finite state machine diagram

- 5 states
- 8 other transitions between states
  - 6 conditioned by input
  - □ 1 self-transition (on 0 from 001 to 001)
  - 2 independent of input (to/from 111)
- 1 reset transition (from all states) to state 100
  - represents 5 transitions (from each state to 100), one a self-arc
  - simplifies condition on other transitions –all would include AND reset')
  - short-hand rather than drawing a transition arc from each state



Spring 2010

CSE370 - XIV - Finite State Machines I

3

#### State diagrams

- Like a program
- Start in some state
- For each state:
  - For all possible input combinations
    - Determine what the next state should be
    - Determine what the output should be
- States are used to remember what happened in the past
  - Typically, being in a state means something, e.g.
    - We've seen an even number of 1's
    - Button A has been pressed
    - We are waiting until the input goes back low
    - We've counted up to 5

Spring 2010

CSE370 - XIV - Finite State Machines I

### Counters are simple finite state machines

- Counters
  - proceed through well-defined sequence of states
- Many types of counters: binary, BCD, Gray-code, etc....
  - a 3-bit up-counter: 000, 001, 010, 011, 100, 101, 110, 111, 000, ...
  - □ 3-bit down-counter: 111, 110, 101, 100, 011, 010, 001, 000, 111, ...



Spring 2010

CSE370 - XIV - Finite State Machines I

#### How do we turn a state diagram into logic?

- Counter
  - 3 flip-flops to hold state
    - clock signal controls when flip-flop memory changes
      - move to next state with clock ticks
      - wait long enough for combinational logic to compute new value
  - Logic to compute next state just an increment function
  - Logic to compute output



Spring 2010

CSE370 - XIV - Finite State Machines I

# Any sequential system be represented with a state diagram

- Shift register
  - input value shown on transition arcs
  - output values shown within state node





Spring 2010

CSE370 - XIV - Finite State Machines I

#### General Finite State Machine Implementation

- The state register holds the current state of the machine
  - Similar to a program counter
  - Different value for each state
- The state machine logic computes:
  - The next state function where the FSM should transition next
  - The output function
    - Function of the current state (Moore)
    - Function of the current state and the inputs (Mealy)



#### FSM design procedure

- Draw the state diagram in all its glory (creative design)
  - List all inputs
  - List all outputs
  - Draw all the states
  - Draw all possible transitions from each state
    - One for each input combination
    - Use don't cares to reduce number
- Decide how each state should be represented using state bits
  - Choice may determine cost/speed of FSM implementation
- Convert state diagram to a state transition table (turn crank)
  - Truth table representation of state diagram
  - Truth table has next state function and output function
- Implement next state function and output function (old hat)

Spring 2010

CSE370 - XIV - Finite State Machines I

a

#### Example FSM design procedure – 8-bit counter

- 8 states 3 state bits
  - Use state to represent count (could use any encoding)
  - Output function is trivial
- State table has an entry for (states x inputs)
  - No inputs here, just states
  - Table output gives next state and output values



| current state |     | next st | ate |
|---------------|-----|---------|-----|
| 0             | 000 | 001     | 1   |
| 1             | 001 | 010     | 2   |
| 2             | 010 | 011     | 3   |
| 3             | 011 | 100     | 4   |
| 4             | 100 | 101     | 5   |
| 5             | 101 | 110     | 6   |
| 6             | 110 | 111     | 7   |
| 7             | 111 | 000     | 0   |

Spring 2010

CSE370 - XIV - Finite State Machines I





#### More complex counter example

- Complex counter
  - repeats 5 states in sequence
  - not a binary number representation
- Step 1: derive the state transition diagram
  - count sequence: 000, 010, 011, 101, 110
- Step 2: derive the state transition table from the state transition diagram



| Pre | sent | State | Nex      | t Stat | te  |
|-----|------|-------|----------|--------|-----|
| С   | В    | Α     | C+       | B+     | A+_ |
| 0   | 0    | 0     | 0        | 1      | 0   |
| 0   | 0    | 1     | <b> </b> | _      | _   |
| 0   | 1    | 0     | 0        | 1      | 1   |
| 0   | 1    | 1     | 1        | 0      | 1   |
| 1   | 0    | 0     | _        | _      | _   |
| 1   | 0    | 1     | 1        | 1      | 0   |
| 1   | 1    | 0     | 0        | 0      | 0   |
| 1   | 1    | 1     | _        | -      | _   |
|     |      |       |          |        |     |

note the don't care conditions that arise from the unused state codes

Spring 2010

CSE370 - XIV - Finite State Machines I

13

#### More complex counter example (cont'd)

Step 3: K-maps for next state functions







$$B+ <= B' + A'C'$$

Spring 2010

CSE370 - XIV - Finite State Machines I

# Self-starting counters (cont'd)

Re-deriving state transition table from don't care assignment











Spring 2010

CSE370 - XIV - Finite State Machines I

# Self-starting counters

- Start-up states
  - at power-up, counter may be in an unused or invalid state
  - designer must guarantee that it (eventually) enters a valid state
- Self-starting solution
  - design counter so that invalid states eventually transition to a valid state
    - this may or may not be acceptable
  - may limit exploitation of don't cares
- Or just use reset





Spring 2010

CSE370 - XIV - Finite State Machines I

# Activity

- 2 inputs (A and B) and 1 output (+ reset)
- If A turns on first, and then B: Turn on output (until reset)
- If B turns on before A: Keep output off (until reset)
- Note that the output is a function of the state only (Moore)



State Assignment

(Arbitrary – different encoding yields different circuits)

Spring 2010

CSE370 - XIV - Finite State Machines I

#### Activity

Convert state diagram to a State Table



| _S1_                  | S0     | Α      | В | N1  | N0     | Out              |
|-----------------------|--------|--------|---|-----|--------|------------------|
| 0                     | 0      | 00     | 0 | 0   | 0      | 0                |
| 0                     | 0      | 0      | 1 | 1   | 1      | 0<br>0           |
| 0                     | 0      | 1      | 0 | 0   | 1      | 0                |
| 0                     | 0<br>1 | 1<br>1 | 1 | 1   | 1      | 0                |
| 0                     | 1      | 0      | 0 | 1 0 | 1      | 0                |
| 0<br>0<br>0<br>0<br>0 | 1      | 0      | 1 | 1   | ō      | 0<br>0<br>0<br>0 |
| 0                     | 1      | 1      | 0 | Ō   |        | 0                |
| 0                     | 1      | 1      | 1 | 1   | 1<br>0 | 0                |
| 1                     | 0      | -      | - | 1   | 0      |                  |
| 1<br>1                | 1      | -      | - | 1   | 1      | 1<br>0           |
|                       |        |        |   |     |        |                  |
|                       |        |        |   |     |        |                  |
|                       |        |        |   |     |        |                  |
|                       |        |        |   |     |        |                  |
|                       |        |        |   |     |        |                  |

State Table

Spring 2010

CSE370 - XIV - Finite State Machines I

# Activity

Implement next state and output functions

#### State Table

| _ 9       | 51     | S0                                     | Α      | В              | N1   | N0               | Out    | <u>.                                    </u> |        |           |        |
|-----------|--------|----------------------------------------|--------|----------------|------|------------------|--------|----------------------------------------------|--------|-----------|--------|
| (         |        | 0                                      | 0      | 0              | 0    | 0                | 0      |                                              |        |           |        |
| (         |        | 0                                      | 0<br>1 | 1<br>0         | 1 0  | 1                | 0      | N1 <= S1 + E                                 | 2      |           |        |
| (         | )      | ŏ                                      | 1      | 1              | 1    | ī                | 0      | N0 <= S1S0                                   |        | 'B + S1'S | ιnΑ'   |
| (         |        | 1                                      | 0      | 0              | 0    | 1                | 0      | Out = S1S0'                                  | . 0100 | В . ОТО   |        |
| (         | )      | 1                                      | 0<br>1 | 1<br>0         | 1 0  | 0<br>1           | 0      |                                              |        |           |        |
| (         | )      | 1                                      | 1      | 1              | 1    | Ō                | 0      |                                              |        |           |        |
|           | 1<br>1 | 0                                      | -      | -              | 1    | 0                | 1<br>0 |                                              |        |           |        |
| _         | L      | - 1                                    |        |                | _ S1 | _                | U      | S1                                           |        | S1 _      | _      |
|           |        |                                        | 0      | 40             | 12 8 | 1                |        | 0 1 2 80                                     | 0 40   | ) 10 1    | ]      |
|           |        |                                        | 1      | <sub>5</sub> 1 | 1 9  | 1]] <sub>B</sub> |        | 1 0 1 0 B                                    | 0 0    | ) 0 1     | ]<br>B |
|           |        |                                        | 1      | 1              | 1 1  | 1]]              |        | 1 0 1 0                                      | 0 (    | 0 1       | 1      |
|           |        | Α                                      | 0      | 0              | 1 10 | 1                | Α      | 0 1 1 0                                      | A 0 6  | 0 1       |        |
|           |        |                                        |        | SC             | )    |                  |        | S0                                           |        | S0        |        |
| Spring 20 | 010    | CSE370 - XIV - Finite State Machines I |        |                |      |                  |        |                                              |        |           |        |

### Edge Detector

- Implement an edge detector
  - Sample an input
  - □ Output a 1 when either the transition 0 -> 1, or 1 -> 0 is detected



Note: Output value is associated with the state. This is a Moore machine.

State assignment has not been done. Symbolic values (A, B, C, D, E) have been used instead.

Spring 2010

CSE370 - XIV - Finite State Machines I

22

#### Edge Detector

- State Table using symbolic states
- Next step: state assignment
- How many inputs do the next state and output functions have?
  - i.e. How large are the K-maps?



Spring 2010 CSE370 - XIV - Finite State Machines I

Edge Detector

- This is a Moore FSM
  - □ The output is 1 if the FSM is in state D or E
  - We can do state assignment so that one state bit is 1 only in state D and E
  - □ e.g. A=000, B=001, C=010, D=100, E=101



Spring 2010

CSE370 - XIV - Finite State Machines I





# Mealy machine

- Output is a function of both the current state and inputs
  - specify output on transition arc between states
  - Detector example
    - Note only 3 states are needed



|       |       | current | next  |        |
|-------|-------|---------|-------|--------|
| reset | input | state   | state | output |
| 1     | -     | -       | Α     | 0      |
| 0     | 0     | Α       | В     | 0      |
| 0     | 1     | Α       | С     | 0      |
| 0     | 0     | В       | В     | 0      |
| 0     | 1     | В       | С     | 1      |
| 0     | 0     | С       | В     | 1      |
| 0     | 1     | С       | С     | 0      |
|       |       |         |       |        |
|       |       |         |       |        |

Spring 2010

CSE370 - XIV - Finite State Machines I

27

### Mealy machine

- State assignment:
  - □ A=00, B=01, C=10

|    | S0 |   |   |    |  |
|----|----|---|---|----|--|
|    | 0  | 0 | Х | 0  |  |
| in | 1  | 1 | Χ | 1  |  |
|    |    |   | 5 | S1 |  |

N1 = in

|       |       | current | next  |        |
|-------|-------|---------|-------|--------|
| reset | input | state   | state | output |
| 1     | _     | _       | 0 0   | 0      |
| 0     | 0     | 0 0     | 0 1   | 0      |
| 0     | 1     | 0 0     | 10    | 0      |
| 0     | 0     | 0 1     | 0 1   | 0      |
| 0     | 1     | 0 1     | 10    | 1      |
| 0     | 0     | 10      | 0 1   | 1      |
| 0     | 1     | 10      | 10    | 0      |



N0 = in'



out = S1in' + S0in

Spring 2010

CSE370 - XIV - Finite State Machines I

# Edge Detector - Implications of Mealy Machine



Note that the output changes as soon as the input changes. But glitches on input get passed along! Output reacts faster, but may add delay to critical path.

Spring 2010 CSE370 - XIV - Finite State Machines I

#### General state machine model revisited

- Values stored in registers represent the state of the circuit
- Combinational logic computes:
  - next state
    - function of current state and inputs
  - outputs
    - function of current state and inputs (Mealy machine)
    - function of current state only (Moore machine)



Spring 2010

CSE370 - XIV - Finite State Machines I

30

#### State machine model (cont'd) States: $S_1$ , $S_2$ , ..., $S_k$ Inputs: I<sub>1</sub>, I<sub>2</sub>, ..., I<sub>m</sub> Outputs: O<sub>1</sub>, O<sub>2</sub>, ..., O<sub>n</sub> Transition function: $F_s(S_i, I_i)$ Output function: $F_o(S_i)$ or $F_o(S_i, I_i)$ output →Outputs logic Inputs< next state Next State logic **Current State Next State** State Clock 0 Spring 2010 CSE370 - XIV - Finite State Machines I 31



### Comparison of Mealy and Moore machines

- Mealy machines tend to have less states
  - outputs depend on arc taken from a state to another state (n²)
     rather than just the state of the FSM (n)
- Moore machines are safer to use
  - outputs change at next clock edge
  - in Mealy machines, input change can cause async output change (after prop delay of logic) – a BIG problem when two machines are interconnected – asynchronous feedback may occur if one isn't careful (input to fsm1, changes output of fsm1, which is an input to fsm2, whose output changes, and turns out to be input to fsm1)
- Mealy machines advantage? they react faster to inputs
  - react in same cycle don't need to wait for clock
  - in Moore machines, more logic may be necessary to decode state into outputs that are needed – more gate delays after clock edge

Spring 2010

CSE370 - XIV - Finite State Machines I

# Verilog for Finite State Machines

- Strongly recommended style for FSMs
- Works for both Mealy and Moore FSMs
- You can break the rules
  - But you have to live with the consequences

Sprint 2010

CSE370 - XV - Verilog for Finite State Machines

Mealy and Moore machines

Moore

Moore

Mealy

Meal

# Constructing State Machines in Verilog

- We need register to hold
- the current state
  - □ always @(posedge clk) block
- We need next state function
  - Where do we go from each state given the inputs
  - state by state case analysis
    - next state determined by current state and inputs
- We need the output function
  - State by state analysis
  - Moore: output determined by current state only
  - Mealy: output determined by current state and inputs

Sprint 2010

CSE370 - XV - Verilog for Finite State Machines

3

#### State Register

- Declare two values
  - state : current state output of state register
  - nxtState : next state input to state register
  - We rely on next state function to give us nxtState
- Declare symbols for states with state assignment

Sprint 2010

CSE370 - XV - Verilog for Finite State Machines

# State Register

- Simple code for register
  - Define reset state
  - Otherwise, just move to nxtState on clock edge

Sprint 2010

CSE370 - XV - Verilog for Finite State Machines

5

#### Next State Function

- Combinational logic function
  - Inputs : state, inputs
  - Output : nxtState
- We could use assign statements
- We will use an always @ (\*) block instead
  - Allows us to use more complex statements
  - □ if
  - case

Sprint 2010

CSE370 - XV - Verilog for Finite State Machines